<template>
  <van-icon
    :color="value ? '#ffa500' : '#777'"
    :name="value ? 'star' : 'star-o'"
    @click="doClick"
  />
</template>

<script>
// 导入 api
import { addCollect, deleteCollect } from '@/api/article.js'

export default {
  name: 'collectArticle',
  props: {
    // 收藏状态
    value: {
      type: Boolean,
      required: true
    },
    // 被收藏的文章id
    aid: {
      type: [Number, String],
      required: true
    }
  },
  methods: {
    // 1.点击按钮方法------------------------
    async doClick() {
      // a.显示提示
      this.$toast.loading({
        message: '操作中...',
        forbidClick: true
      })
      try {
        if (this.value) {
          // 取消收藏操作
          await deleteCollect(this.aid)
        } else {
          // 添加收藏操作
          await addCollect(this.aid)
        }
        this.$toast.success('操作成功~: )')
        // 修改 父组件 上 关注状态
        this.$emit('input', !this.value)
      } catch (err) {
        this.$toast.fail('操作失败~: {')
      }
    }
  }
}
</script>

<style lang="less" scoped>
</style>
